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INTRODUCTION 


The Cromemco 88-CCC Cyclops Camera Controller is designed to provide 
high-speed Direct Memory Access (DMA) from a Cromemco Altair Cyclops 

Camera (model 88-ACC) to an Altair 8800 or Imsai 8080 computer, By using 
direct memory access a picture can be loaded very quickly from the camera 
with a minimum of software overhead, The Cyclops Camera Controller together 
with the Altair Cyclops Camera and your microcomputer now provide for the 
first time anywhere a low-cost computerized system for measurement, 
recognition, and control. 


ASSEMBLY 


The 88-CCC is built on two circuit boards designed to plug directly 
into an Altair 8800 or Imai 8080 computer, A 16-conductor ribbon 
cable, with DIP plugs on each end, is provided to intercormect the 
two circuit boards, The circuit boards are of the highest quality 
complete with solder-resid mask, a silk-screened legend mask to show 
component placement and gold-plated edge contacts. 


If you purchased your 88-CCC as a kit (model 88-CCC-K) you will find 
assembly straightforward, IC sockets are provided for all ICs, and the 
printed legend mask on each circuit card shows precisely where each part 
is placed, All DIP ICs should be oriented in their sockets with pin 

one toward the lower left corner of the board, 


A complete parts list for the 88-CCC is given on the last page of this 
manual, 


Inter-board Connection 


IC sockets should be installed in the upper right-hand corner position 
of both board 1 and board 2, The 16-conductor ribbon cable provided 
can then be used to interconnect the two boards, Be sure that pin 1 
of the socket on board 1 is connected to pin 1 on board 2, pin 2 to 
pin 2, etc, 


Port Address Selection 


Port select jumper wires should be installed on 88-COC Board 2 as shown 
with the silk-screened legend mask on the board, The jumper wires can 
be connected in other ways to change the port address selection ( this 
4s described in detail on the following pages.) 


Output connection 

A 16-pin DIP socket on 88-CCC Board 1 (near the upper left corner of 
the board) is used to connect the 88-CCC to the Altair Cyclops Camera, 
Pins 1 to 4 connect to pins 1 to 4 of the connector on the rear of the 
Altair Cyclops Camera, Pin 6 connects to piné of the camera, Pin 8 
connects to pin 8 of the camera, No connection need be made to pin 5, 
7, oc 9 of the Altair Cyclops Camera, 


88-CCC PORT ADDRESS SELECTION 


Communication between the 88-CCC and the Altair computer 
takes place through three output ports and one input 

port, These are: output port A, output port B, output port Cc, 
and input port A. Six jumper wires are used on the 
component side of Board 2 to select the port addresses. 


One end of one jumper wire is soldered to pad O and the 
other end either to pad L or pad R immediately above 

pad 0. One end of a second jumper wire is soldered to 

pad 1 and the other end either to pad L or pad R immediately 
below pad 1. The remaining four jumper wires are connected 
similarly as shown in the diagram below. 


Since one end of each of the jumper wires can connect to 
either the corresponding pad on the left (L) or on the 
right (R) there are a total of 64 possible different ways 
to connect the jumper wires, Each of these 64 different 
ways assigns different port addresses to port A, port B, 
and port C. This is shown in the table below: 


VAVAVA oo ce ore 


Port A Port 3B Port © 


R R R R RR 000 ‘elena 002 
L R R R RR 004 ~ 005 006 
R L R R R R O10 O14 012 
L L- R R RR 014 O15: 016 
R R L R R R 020 O21 | 022 
L R L R R R 024 025 026 
R L L R R R 1030 031 032 
Lb. SG L R R R 034 035 036 
R R R L R R O40 O41 O42 
L R Ra RR O44 O45 O46 
R L R L R R 050 051 052 
LL R L R R O54 055 056 
R R L L R R 060 - O61 062 
'L R L & R R 064 065 - 066 
R L Le R R 070. O71: 072 
oa 21 TG R R O74 O75 076 
R R R R L R 100 101 102 
L oR R R L R 104 105 106 
R L R R LR 110 , t4. 112 
LoL R R L R 1414 115 116 
R R L R IeccR 120 121 122 
L R L R L R 124 125 126 
R L L R L R $130 131 132. 


(Cont. ) 


PORT ADDRESS SELECTION (CONTINUED) 


JUMPER WIRE CONNECTION PORT ADDRESSES 
EG L R L R | 134 135 136 
RR R L L R 140 141 Lao 
L R R L L R “144 145 146 
R L R L L R 150 151 152 
ae R L L R 154 155 156 
R R b. h L R 160 161 162 
L R je L R 164 165 166 
R L i. L R 170 171 172 
L L TE Ts L R 174 175 176 
R R R R R L 200 201 202 
L R R R R L 204 205 206 
R L R R R L 210 211 212 
i VL R R R L 214 215 216 
R R fe oR RL 220 204 noo 
TR L R RL 224 225 226 
R 1 L R R L 230 231 232 
Te SE ee - R L 234 235 236 
R R R L R - 20 ahi 2he2 
L R R L R LB 2H 245 26 
R 4 R L R L 250 251 252 
Te OG R L R L 254 255 256 
R R L L R 260 261 262 
L R Tee R L 264 265 266 
R - Ls a R L 270 271 e002 
ee i, R L 20 275 276 
R R R R ae ee 300 301 302 
L R R R T.-L 304 305 306 
R L. R R T.-. t 310 311 312 
ie R R i. & 314 315 316 
R R L R eee? 320 321 322 
L R L R ‘Fae 324 325 326 
Ro L R Te (3G 330 331 a32 
li L R Le: oly 334 335 336 
R R R Lb LL 340 BH 342 
L oR R L eG 344 345 346 
R L R 1 Te. 350 351 5e 
Li, oy R L Ty «as 354 355 356 
R R Tey > Le. 3G 360 361 362 
L R Ti. LoL 364 365 366 
Roo 3G LE L GG 370 eye oe 
ee Li. ob ae 374 375 376 


* For compatibility with Cromemco software we recommend this 
port assignment: Port A - 020; Port B - 021; Port C - 022, For 
this port assignment connect the address selection jumper wires 
as shown in this diagram: 


() Aa 


Viewed from component 
side of Board 2, 


0 0 0 


88-CCC Control Words 


As stated previously, communication between the 88-CCC and 
the Altair computer takes place through three output ports 
and one input port. The addresses assigned to these ports 
are user selectable, as described in the previous section. 
The storing of the video information from the Cyclops 
Camera does rot take place through these control ports, 
but rather occurs through Direct Memory Access. 


The information transferred through each input/output 
port is called a control word. In this section we 
deseribe the control word format, and discuss precisely 
how the control words are used, 


Output Control Word A 


Control Word A, which is output to port A, contains §& bits 
to communicate the following information to the 88~+CCC 
interface board: 


Bit Description 
Oo LSB Auxiliary output to select 
1 ¢é one of sixteen Cyclops 
2 Cameras or for other user 
ce MSB defined functions. 
4 Not used. 
5 For control of the bias light 


in the Cyclops Camera. High 
logic level for lights on. Low 
logic level for lights off. 


6 Not implemented on 88-CCC REV 1. 
Reserved for possible future use in 
enabling interrupt circuitry. 


7 When high, 88-CCC is signaled to 
store one frame of a picture 
in memory using Direct Memory 
Access, 


Input Control Word A 


Input Control Word A,at input port A, is used to echo Output 
control word A. Bit 7 is high during frame store but is 
reset to 0 following the completion of a frame store. The 
user thus has two options for detecting the completion of 

a frame store: 1) By having the’ 88-CCC generate an interrupt 
(bit 6 of output control word A must be high to enable 

the interrupt generation) or 2) By polling bit 7 of input 
control word A, 


Qutput Control Word B 


To understand the use of control word B it is first necessary 
to understand how the Cyclops Camera encodes gray-scale 
information, The photodiodes of the Cyclops C-1024 image 
sensor are used in what is called charge-storage mode, 

What this means is that the capacitance of each diode 

is charged to some voltage level just prior to taking 

a frame of the picture. The voltage across each diode 

is decreased as light falls on the diode. 


The entire array of 1024 photodiodes may be scanned up 
to 15 times during a single frame of the picture, (The 
precise number of times is set by Control Word B). 
Each scan produces a single field of the picture. 

Each field consists of 1024 bits of information which 
is stored in 128 bytes of memory. Each bit of the 
field corresponds to one of the photodiodes in the 
image sensor. If sufficient light has fallen on a 
particular diode to drop its voltage below a threshold 
value, the corresponding bit in the field is a 1. 

If the voltage on the diode is still above threshold 
the corresponding bit in the field is a 0, 


The time delay between subsequent fields determines the 
coarseness of gray-scale quantization. This time 
delay is also set by Control Word B. 


Bit # Description 
O°) LSB Specifies the number of fields 
1 to be stored in memory. 128 
C bytes of memory are required 
2 for each field 
oy MSB 
4 > LSB Specifies the number of 2 - 
5° MSB - millisecond increments 
2 separating each field. 
6 Not used. 
7 Not used. 


Output Control Word ¢ 


The eight bits of Control Word C set the starting address 
in memory for the DMA frame store. The starting address 
is as shown below, where DO through D7 are the eight 

bits of the control word: 


A15 A14 A13 A1l2 Ait A10 AQ A8 ‘A7 A6 A5 AY AZ AZ Al AO 
Oo Db? D6 DS DY D3D2D1D0 00000 0 0 


CYCLOPS CAMERA AND OUTPUT CONNECTION 


A sixteen pin DIP socket on 88-CCC Board 1 is used for connection to 
the Altair Cyclops camera and for auxiliary connections. The 
pin assignment for thses 16 pins is as follows: 


PIN # FUNCTION 


1 Ground 


2 Composite clock, This signal increments 
the 88-ACC sean counters with 1 microsecond 
pulses, The scan counters are reset with 
either a 5 or 17 microsecond pulse on this 
line, A 5 microsecond pulse is used to reset 
the scan counters and turn off the 88-ACC 
bias lights. A 17 microsecond pulse is used 
to reset the scan counters and turn on the 
88-ACC bias lights. 


3 Data input from 88-ACC, 
4 +17 volt supply 
5 NO CONNECTION 
6 Pull up resistor to +5 volts. 
7 NO CONNECTION 
8 -17 volt supply 
Rear Connector 9 NO CONNECTION 
of 88-ACC 
10 Clock 
sl ' Reset 
12 (MSB)™ 
Bits DO to D3 of output control word A. 
13 These four bits may be used as a 
14 general purpose output port for such 
functions as selecting one of 16 cameras, 
15 (LSB) 
16 +5 volt supply 


SOFTWARE SUPPORT 


PROGRAM: ccc~1 
TO INITIALIZE PORTS AND STORE A SINGLE FRAME OF 15 FIELDS IN MEMORY 


To understand the operation of the 88-CCC Cyclops Camera Controller, 
it is important to understand the operation of this program. 

The program assumes that the preferred address selection is 
used(i.e. port A = 020, port B = 021, and port C = 022), The 
program should be loaded using the switches on the front 

panel of the Altair starting at memory location 000 000, 


MEMORY. LOCATION INSTRUCTION COMMENTS 
000 076 (MVIA)Moves immediate into the accumulator 


the starting address of where the 


O01 OG picture is to be stored in memory. 
Here the starting address is chosen 
to be at 000 200. 

002 323 (OUT) The starting address is now output 
from the accumulator to output 

003 022 port 022 

0o4 076 (MVIA)Control word B is moved into the 

005 017 accumulator and output to port 

006 323 (OUT) 021 to specify that 15 fields per 

007 021 frame will be stored with a 2 msec 
spacing between fields. 

010 076 (MVIA)Control word A is moved into the 

011 200 accumulator and output to port 020 

012 323 (OUT) to begin the storing of a single 

013 020 frame of the picture. 

O14 333 (INP) Input port 020 is now polled to 

015 020 determine whether the frame store 

016 346 (ANI) is complete 

OL7 200 

020 302 (JNX) 

O21 O14 

022 000 

023 303 (JMP) After the picture is stored the 

O24 023 program remains in this loop until 

025 000 program execution is stopped by 


activating the "STOP" switch on 
the Altair front panel. 


SOFTWARE SUPPORT 
PROGRAM: CCC-2 


TO DISPLAY A FRAME OF 15 FIELDS ON A TELETYPE 


This program begins with program CCC-1 to store 15 fields 

in the computer memory. CCC-1 is modified to have a higher 
starting address so that data is not written over the program. 
CCC-1 is further modified to end not in a loop, but rather 
ina i to the beginning of the display program (at location 
000 030). 


MEMORY LOCATION INSTRUCTION COMMENTS 


000 O76 
002 
323 
022 
076 
O17 
323 
One This is the 
200 modified version 
er of program CCC-1 
333 
020 
346 
200 
302 
O14 
000 
303 
030 
000 


030 061 LXI SP 
377 These two bytes should 
000 indicate the top of memory 
O41 LXI H,L 
200 
000 
006 
000 
016 
000 
026 
000 
000 
000 NOPs 
000 
000 
000 


These instructions 
are to initialize 
counters. 


PROGRAM CCC-2 (Continued) 


MEMORY LOCATION INSTRUCTION COMMENTS 
O51 170 
376 
O40 


Test to see if 


ghe register B = 32. 


200 
000 
171 
376 | 
004 Test to see if 
312 register C = 4, 
145 
000 
172 
376 
010 Test to see if 
312 register D = 8. 
140 
000 

073 OLS 
230 
000 
173 
007 
137 
33e Jump on carry to 
130 type a space. 
000 
303 Otherwise jump to 
120 type a dot, 
000 


The following are subroutines to the main program: 


120 076 
056 
323 
Oo1 Subroutine to type 
o24 dot. 
303 
065 
000 
076 
102 
323 Subroutine to type 
ool space. 
O24 
303 
065 
000 
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PROGRAM CCC-2 (Continued) 


Memory Location Instruction Comments 


140 053 
014 
303 
O42 
000 
315 
230 
000 
076 
O15 
323 
001 
210 
230 
000 
076 


aoe Return carriage 


re and line feed, 


004 
O21 
010 
000 
O31 
303 
O40 
000 


200 315 
230 
000 
076 


O12 Generate a linefeed 


ee between fields. 


BL) 
230 
000 
076 
012 
323 
001 
303 
036 
000 


230 333 
000 
346 Test input port 000 
002 until teletype 
312 is ready, then 
230 return, 
000 
311 


ih 


Memor 


SOFTWARE SUPPORT 


PROGRAM: 


ccc-3 


PROGRAM FOR CYCLOPS DISPLAY WITH THE CROMEMCO DAZZLER 


y 


location Op Code Mnemonic 


000 


O24 


076 
213 


323 
O16 
076 
000 
323 
017 


076 
O40 
323 
022 
076 
013 
323 
021 
076 
200 
323 
020 
333 
020 
346 
200 
302 
O2k 
000 
303 
100 
000 


MVI A 


OUT 
MVI A 
OUT 


MVYI A 
OUT 
MVI A 
OUT 
MVI A 


OUT 


JNZ 


JMP 


Comme nts 


Set start of Dazzler picture 
display at 5.5K 


Set Dazzler for 32X32 mode 
black and white display 


Set 88-CCC to start storing Cyclops 
data at location 4K in memory 


Set 88-CCC to collect 12 fields 
from the Cyclops camera at 2 ms, 
spacing 


Command to start storing Cyclops 
picture in memory, 


Poll port 020 to see if pActure 


storage is complete, 


Jump back if not through, 


Go to the start of the packing 
program when picture storage is 
complete. 


** Comment: the purpose of the following routine. is to repack 
the Cyclops picture into a format so that it will be properly 
displayed on a TV screen by the Dazzler TV interface, ** 


100 


061 
000 
020 
O44 
000 
000 
O71 
174 


LXI SP 


LXI H 


DAD SP 
MOV A, H 


12 


Set SP to camera data start point, 


Clear H,L 


SP to HL 


H to A 


Software CCC-3 Continued 


110 3h6 ANT Strip bit count 
340 
017 RRC 
306 ADI 
014 
107 MGV B,A 
174 MOV A,H 
346 ANI 
037 
147 MOV H,A 
353 XCHG 
OA LAI H 
000 
000 
OF1 DAD SP 
051 DAD H 
322 JING 
134 
000 
O43 INX H 
054 DAD H 
322 ING 
144 
000 
O43 INX H 
174 MOV A,H 
346 ANT 
oot 
366 ORI 
026 
147 MOV H,A HL now has byte address for picture 
170 MOV A,B location corresponding to packing 
346 ANI _ start in DE, 
020 
076 MVI A 
O17 
302 JINZ 
161 
000 
076 MVI A 
340 
246 ANA M 
167 MOV M,A 
170 MOV A,B 
346 ANI 
360 
O17 RRC 
O17 REG 
O17 RRG 
O17 RRG 
117 MOV C,A 
032 LDAX DE Get camera data from DE 
O14 INR C 


175 


017 
O15 
302 
175 
000 
322 
211 
000 
170 
346 
020 
076 
020 
302 
217 
000 
076 
O01 
206 
167 
005 
076 
200 
203 
137 
076 
000 
212 
127 
170 
346 
O17 
302 
163 
000 
O44 
000 
000 
074 
174 
306 
O40 
147 
322 
254 
000 
043 
371 
175 
376 
200 
332 
107 
000 
303 
000 
000 


Software CCC-3 Continued 


JINZ Jump if need more camera frames, 


JMP Jump back to the beginning, 


14 


ERRATUM 


There is a foil error on 88 CCC Board 1 REV 1. In particular address 
line A8 (edge connector contact 84) and line A9 (edge contact 34) are 
interchanged, If A8 and A9 are used to address memory during the 

DMA operation the picture will not be stored sequentially but will be 
jumbled by the interchange of A8 and A9. For many applications 

this will have no effect on system performance (e.g, security systems), 
There are one of two possible fixes to correct the interchange of 

A8 and AJ: 1) on 88 CCC Board 1 cut the foil leading to edge contact 
84 and contact 34. Jumper the wire that use to go to 84 to 34, and the 
wire that use to go to 34 to 84, OR 2) No foil cuts are necessary if 
in your software you correct for AB and AQ being reversed during 
picture storage. Since most applications require considerable software 
anyway, this software fix may be more desireable for some people, 
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88-CCC-K_ Packing List 


88-CCC Board 1 88-CCC Board 2 — 
Ca stad 4. Py 
6 = 7475 3 - 7430 
3 = 7493 2 = 7493 
1 - 7408 3 - 7400 
1 - 7AL5t Z- 7402 
1 - 7420 h ~ 7495 
2 - 7485 1 - 74464 
2- 793 1 - 7440 
ae ies 3 - 7405 
1 - 7402 2 - 74h 
3 - 74367 3 - 74367 
1 - 1N914 4» LM 340T ~ 5 
1+ 1.5K + watt resistor (Rt) 1 - Heatsink 
S Fy 1 - 6-32 X 3/8 screw 
1 - 560 a watt resistor (R2) fw Bb2 aut a 
; a ee 2 2-~ Filter capacitors 
1 - 6-32 X 3/8 screw (note polarity) 
1 = 6-32 nut 9- 0,1 uF dise capacitors 
2 - Filter capacitors(Note 


polarity when inserting) 
9 - 0.1 uF disc ceramic capacitors 


Id SOCKETS 


2} 16 pin 
34 414 pin 


Other 


146-conductor ribbon cable 
jumper with DIP plugs on both 
ends, (For inter-board connection) 


16-pin DIP plug to plug into the 
"TO CYCLOPS" socket, 


88-CCCG Manual, 


Please report any shortages immediately to our sales office: 
CROMEMCO, ONE FIRST STREET, LOS ALTOS, CALIFORNIA, 94022 


(415) 941-2967 
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